/**
 * @author LKQ
 * @date 2021/12/23 20:03
 * @description 使用递归
 */
public class FormalSolution2 {
    public static void main(String[] args) {
        FormalSolution2 solution = new FormalSolution2();
        ListNode listNode6 = new ListNode(6);
        ListNode listNode5 = new ListNode(5, listNode6);
        ListNode listNode4 = new ListNode(4, listNode5);
        ListNode listNode3 = new ListNode(3, listNode4);
        ListNode listNode2 = new ListNode(2, listNode3);
        ListNode listNode1 = new ListNode(1, listNode2);
        ListNode listNode = solution.reverseList(listNode1);
        System.out.println(listNode);
    }


    public ListNode reverseList(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        ListNode newHead = reverseList(head.next);
        head.next.next = head;
        head.next = null;
        return newHead;
    }
}
